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Preface 


This manual is the Programmer’s Reference Manual for as — the assembler for the UNEXf system 
running on the Sun Workstation. As converts source programs written in Assembler Language 
into a form that the linker utility, ld( 1) will turn into a program that is runnable on the UNIX 
operating system. 

As provides the assembly language programmer with a minimal set of facilities to write programs 
in assembly language. Since the majority of programming is done in high level languages, as 
doesn’t provide any elaborate macro facilities or conditional assembly features. It is assumed 
that the volume of assembly code produced is so small that these facilities aren’t required. 

This manual describes the syntax and usage of the as assembler for the Motorola MC68010 
microprocessor. The basic format of as is loosely based on the Digital Equipment Corp Macro-11 
assembler described in DEC’s publication DEC-11-0MACA-A-D but also contains elements of the 
UNIX PDP-11 as( 1) assembler. The instruction mnemonics and effective address format are 
derived from a Motorola publication on the MC68000: the MACSS MC68000 Design 
Specification Instruction Set Processor dated June 30, 1979. 

This is a reference manual as opposed to a treatise on writing in assembly language. It is 
assumed that the reader is familiar with the concepts of machine architecture, the reasons for an 
assembler, the ideas of instruction mnemonics, operands, and effective address modes, and assem- 
bler directives. It is also assumed that the reader is familiar with the MC68010 processor, its 
instruction set, its addressing modes, and especially the irregularities in them. 


t UNIX is a trademark of Bell Laboratories. 
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Chapter 1 


Introduction 


1.1. How to Use the Assembler 

By convention, the assembly language source code of the program should be in a file with a 
suffix. Suppose that your program is in a file called parts. s. To run the assembler, type the 
command: 

tutor ial% a® parts 


As runs silently (if there are no errors), and generates a file called a. out. 

As also accepts several command line options. These are: 

— o file 

Place the output of the assembler in file. 

— R Make initialized data segments read only (actually the assembler places them at the end of 
the .text area). 

— L Keep local (compiler generated) symbols that start with the letter L. This is a debugging 
feature. If the — L option is omitted, the assembler discards those symbols and does not 
include them in the symbol table. 

— j Make all jumps to external symbols (jsr and jmp) PC relative rather than long absolute. 

This is intended for use when the programmer knows that the program is short. If there 
are any externals which are too far away, the loader will complain when the program is 
linked. 

— J Suppress span-dependent instruction calculations and force all branches and calls to take 
the most general form. This is used when assembly time must be minimized, but program 
size and run time are not important. 

— h Suppress span-dependent instruction calculations and force all branches to be of medium 
length, but all calls to take the most general form. This is used when assembly time must 
be minimized, but program size and run time are not important. This option results in a 
smaller and faster program than that produced by the — J option, but some very large pro- 
grams may not be able to use it because of the limits of the medium-length branches. 

— d2 This is intended for small stand-alone programs. The assembler makes all program refer- 
ences PC relative and all data references short absolute. Note that the — j option does half 
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this job anyway. 

Readers should also consult the UNIX Programmer’s Manual page for the man entry on as. 

1.2. Notation 

The notation used in this chapter is a somewhat modified Backus-Naur Form (BNF). A string of 
characters on its own stands for itself, for example: 

WIDGET 

is an occurrence of the literal string ‘WIDGET’, and: 

1983 

is an occurrence of the literal constant 1983. An element enclosed in < and > signs is a non- 
terminal symbol, and must eventually be defined in terms of some other entities. For example, 

<identifier> 

stands for the syntactic construct called ‘identifier’, which is eventually defined in terms of basic 
objects. A syntactic object followed by an ellipsis: 

<thing> . . . 

denotes one or more occurrences of <fAmy>. Syntactic objects occuring one after the other, as 
in: 

<first thing> <second thing> 

simply means an occurrence of first thing followed by second thing . Syntactic elements 
separated by a vertical bar sign ( J), as in: 

<letter> | <digit> 

means an occurrence of </effer> or <Cdigit> but not both. Brackets and braces define the order 
of interpretation. Brackets also indicate that the syntax described by the subexpression they 
enclose is optional. That is: 

[ <thing > ] 

denotes zero or one occurrences of <thing>, while: 

{ <thing one> \ <thing two>}<thing three> 
denotes a <thing one> or a <thing two> , followed by a <thing three>. 
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1.3. Further Reading 

Motorola MC68010 16-bit Microprocessor Programmer’s Reference Manual. 
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Chapter 2 


Elements of Assembly Language 


This chapter covers the lexical elements which comprise an assembly language program. The 
next chapter discusses the rules for expressions and operand formation. Topics covered in this 
chapter are: 

© Character set which the assembler recognizes, 

® Rules for identifiers , 

@ Syntax for numeric constants, 

• Syntax for string constants, 

© Rules for comments, 

• Layout of an assembly language source statement. 

An assembly language program is ultimately constructed from characters. Characters are com- 
bined to make up lexical elements or tokens of the language. Combinations of tokens then form 
assembly language statements, and sequences of statements then form an assembly language pro- 
gram. This section describes the basic lexical elements of as. 

2.1. Character Set Which the Assembler Recognises 

As recognizes the following character set: 

© The letters A through Z and a through z. 

® The digits O through 9. 

© The ASCn graphic characters — the printing characters other than letters and digits. 

• The ASCII non-graphics: space, tab, carriage return, and newline (also known as line feed). 


2.2. Identifiers 

Identifiers are used to tag assembler statements (where they are called labels), as the location tag 
for data, and as the symbolic names of constants. 

An identifier in an as program is a sequence of from 1 to 255 characters from the set: 

# Upper case letters A through Z. 
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® Lower case letters a through z. 

® Digits 0 through 9. 

© The characters underline ( _ ), period ( . ), and dollar sign ( $ ). 

The first character of an identifier must not be numeric. Other than that restriction, there are a 

few other points to note: 

® All 255 characters of an identifier are significant and are checked in comparisons with other 
identifiers. 

• Upper case letters and lower case letters are considered distinct, so that ki"t_of_part:s 
and KIT_OF_PARTS are two different identifiers. 

® Although the period ( . ) and dollar sign ( $ ) characters can be used to construct identifiers, 
they are reserved for special purposes (pseudo-ops for instance) and should not appear in 
user-defined identifiers. 

Examples of Identifiers 

Grab_Hold Widget Pot_of_Message MAXNAME 


2.3. Numeric Labels 

A numeric label consists of a digit 0 to 9 followed by a colon. As in the case of name labels, a 
numeric label assigns the current value of the location counter to the symbol. However, several 
numeric labels with the same digit may be used within the same assembly. References of the 
form nb refer to the first numeric label n backwards from the reference; nf symbols refer to the 
first numeric label n /orwards from the reference. 


2.4. Local Labels 

Local labels are a special form of identifier which are strictly local to a control section. Local 
labels provide a convenient means of generating labels for branch instructions and such. Use of 
local labels reduces the possibility of multiply defined labels in a program, and separates entry 
point labels from local references, such as the top of a loop. LocaL labels cannot be referenced 
from outside of the current assembly unit. Local labels are of the form n$ where n is any 
integer. Valid local labels include: 

1$ 27$ 394$ 


2.5. Scope of Labels 

The scope of a label is the ‘distance’ over which it is visible to other parts of the program which 
want to reference it. An ordinary label which tags a location in the program or data is visible 
only within the current assembly. An identifier which is designated as an external identifier via 
a .globl directive is visible to other assembly units at link time. 
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Local labels have a scope, or span of reference, which extends between one ordinary label and 
the next. Every time an ordinary label is encountered, all previous local labels associated with 
the current location counter are discarded, and a new local label scope is created. The following 
example illustrates the scopes of the different kinds of labels: 


first: 

addl 

dO, dl | 

creates a new local label scope 

100$: 

addqw 

bees 

#7,d3 | 

100$ | 

first appearance of 100$ 
branches to the label above 

second : 

andl 

#0x7 f f , d4 | 

above 100$ has gone away 

100$: 

empw 

beqs 

dl , d3 | 
100$ | 

this is a different 100$ 

branches to the previous instruction 

third: 

mow 

beqs 

d0,d7 | 

100$ | 

now 100$ has gone away again 

generates an error message if no 100$ below 


The labels first, second , and third all have a scope which is the entire source file containing 
them. The first appearance of the local label 100$ has a scope which extends between first and 
second. The second appearance of the local label 100$ has a scope which extends between 
second and third. After the appearance of the label third, the branch to 100$ will generate an 
error message because that label is no longer defined in this scope. 


2.6. Constants 

There are two forms of constants available to as users, namely numeric constants and string con- 
stants. All constants are considered absolute quantities when they appear in an expression (see 
section 3 for a discussion on absolute and relocatable expressions). 


2.7. Numeric Constants 

As assumes that any token which starts with a digit is a numeric constant. As accepts numeric 
quantities in either decimal (base 10), hexadecimal (base 16), or octal (base 8) radices. Numeric 
constants can represent quantities up to 32 bits in length. 

Decimal numbers consist of between one and ten decimal digits (0 through 9). The range of 
decimal numbers is between —2,147,483,648 and 2,147,483,647. Note that you can’t have com- 
mas in decimal numbers even though they are shown here for readability. Note also that 
decimal numbers can’t be written with leading zeros, because a numeric constant starting with a 
zero is taken as either an octal constant or a hexadecimal constant, as described below. 

Hexadecimal constants must start with the notation Ox (zero-ex) and can then have between one 
and eight hexadecimal digits. The hexadecimal digits consist of the decimal digits O through 9 
and the hexadecimal digits a through f or A through F. 

Octal constants must start with the digit 0. There can then be from one to 11 octal digits (0 
through 7) in the number. But note that 11 octal digits is 33 bits, so the largest octal number is 
037777777777. The assembler generates an error message if the decimal digits 8 and 9 appear in 
an octal constant. 


Revision E of 15 May 1985 


2-3 



Elements of Assembly Language 


Assembly Language Reference Manual 


2.8. String Constants 

A string is a sequence of ASCII characters, enclosed in quote signs ". 

Within string constants, the quote sign is represented by a backslash character followed by a 
quote sign. The backslash character itself is represented by two backslash characters. Any 
other character can be represented by a backslash character followed by one, two, or three octal 
digits. The table below shows the octal representation of some of the more common non printing 
characters. 


Character 

Octal 

Representation 

Backspace 

010 

Horizontal Tab 

on 

Newline (Line-Feed) 

012 

Form-Feed 

014 

Carriage-Return 

015 


2.9. Assembly Location Counter 

The assembly location counter is the period character ( . ). It is colloquially known as dot. 
When used in the operand field of any statement, dot represents the address of the first byte of 
the statement. Even in assembler directives, dot represents the address of the start of that 
assembler directive. For example, if dot appears as the third argument in a . long directive, 
the value placed at that location is the address of the first location of the directive — dot is not 
updated until the next machine instruction or assembler directive. For example: 

Ralph: xnovl . , aO | load value of Ralph into aO 

At the beginning of each assembly pass, the assembler clears the location counter. Normally, 
consecutive memory locations are assigned to each byte of generated code. However, the loca- 
tion where the code is stored may be changed by a direct assignment altering the location 
counter: 


. = <expression> 


This <expres8ton> must not contain any forward references, and must not change value from 
one pass to another. Storage may also be reserved be advancing dot. For example, if the 
current value of dot is 1000, the direct assignment statement: 

Table: .=.+0x100 

reserves 256 bytes (100 hexadecimal) of storage, with the address of the first byte as the value of 
Table. The next instruction is stored at address OxllOO. Also see the .skip assembler direc- 
tive for another means of achieving the same effect. 
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The value of dot is always relative to the start of the current control section. For instance: 

. = 0x1000 

does not set dot to absolute location 0x1000, but to location 0x1000 relative to the start of 
the current control section. This practice is not recommended. 
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Expressions 


Expressions are combinations of operands (numeric constants and identifiers) and operators, 
forming new values. The sections below define the operators which as provides, then gives the 
rules for combining terms into expressions. 


3.1. Operators 

Identifiers and numeric constants can be combined, via arithmetic operators, to form expres- 
sions. As provides unary operators and binary operators, described below. 



Unary Operators 

Operator Function 

Description 

— unary minus 

Returns the two’s complement of its following argu- 
ment. 

• logical negation 

Returns the one’s complement (logical negation) of 
its following argument. 


Operator 

Function 

Binary operators 

Description 


addition 

Arithmetic addition of its arguments. 

— 

subtraction 

Arithmetic subtraction of its arguments. 

a 

multiplication 

Arithmetic multiplication of its arguments. 

/ 

division 

Arithmetic division of its arguments. Note that 
division in as is integer division, which truncates to- 
wards zero. 


Each operator is assumed to work on a 32-bit number. If the value of a particular term occupies 
only 8 bits or 16 bits, the short quantity is sign extended to a full 32-bit value. 
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3o2* Terms 

A term is a component of an expression. A term may be one of the following: 

© A numeric constant, whose 32-bit value is used. The assembly location counter, known as 
dot, is considered a number in this context. 

© An identifier. 

• An expression or term enclosed in parentheses () . Any quantity enclosed in parentheses is 
evaluated before the rest of the expression. This can be used to alter the normal left-to-right 
evaluation of expressions — for example, differentiating between a*b+c and a* (b+c) or to 
apply a unary operator to an entire expression — for example, — (a*b+c) . 

® A term preceded by a unary operator. For example, both double_plus_ungood and 
~double_plus_ungood are terms. 

Multiple unary operators can be used in a term. For example, — positive has the same 
value as positive. 


3.3* Expressions 

Expression are combinations of terms joined together by binary operators. An expression is 
always evaluated to a 32-bit value. 

If the operand only requires a single byte value (a .byte directive or an addq instruction, for 
example) the low order eight bits of the expression are used. 

If the operand only requires a single 16-bit word value (a .word directive or an movem instruc- 
tion, for example) the low order 16 bits of the expression are used. 

Expressions are evaluated left to right with no operator precedence. Thus 
1 + 2*3 

evaluates to 9, not 7. Unary operators have precedence over binary operators since they are 
considered part of a term, and both terms of a binary operator must be evaluated before the 
binary operator can be applied. 

A missing expression or term is interpreted as having a value of zero. In this case, an Invalid 
expression error is generated. 

An Invalid Operator error means that a valid end-of-line character or binary operator was not 
detected after the assembler processed a term. In particular, this error is generated if an expres- 
sion contains an identifier with an illegal character, or if an incorrect comment character was 
used. 


3.4. Absolute, Relocatable, and External Expressions 

When an expression is evaluated, its value is either absolute, relocatable, or external: 
An expression is absolute if its value is fixed. 

© An expression whose terms are constants is absolute. 
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® An identifier whose value is a constant via a direct assignment statement is absolute. 

9 A relocatable expression minus a relocatable term is absolute, where both items belong to the 
same program section. 

An expression is relocatable if its value is fixed relative to a base address, but will have an offset 
value when it is linked or loaded into memory. All labels of a program defined in relocatable sec- 
tions are relocatable terms. 

Expressions which contain relocatable terms must only add or subtract constants to their value. 
For example, assuming the identifiers widget and blivet were defined in a relocatable sec- 
tion of the program, then the following demonstrates the use of relocatable expressions: 


Expression 

Description 

widget 

is a simple relocatable term. Its value is an offset 
from the base address of the current control section. 

widget+5 

is a simple relocatable expression. Since the value 
of widget is an offset from the base address of the 
current control section , adding a constant to it does 
not change its relocatable status. 

widget*2 

Not relocatable. Multiplying a relocatable term by a 
constant invalidates the relocatable status. 

2— widget 

Not relocatable , since the expression cannot be 
linked by adding widget’s offset to it. 

widget— blivet 

Absolute, since the offsets added to widget and blivet 
cancel each other out. 


An expression is external (or global) if it contains an external identifier not defined in the current 
program. With one exception, the same restrictions on expressions containing relocatable 
identifiers apply to expressions containing external identifiers. The exception is that the expres- 
sion 


widget —b 1 ivet 

is incorrect when both widget and blivet are external identifiers — you cannot subtract an exter- 
nal relocatable expression. In addition, you cannot multiply or divide any relocatable expression. 


Revision E of 15 May 1985 


3-3 






Chapter 4 


Layout of an Assembly Language Source Program 


An as program consists of a series of statements. Several statements can be written on one line, 
but statements cannot cross line boundaries. The format of a statement is: 

[< label field>] [ < op-code> [< operand field>] } 

It is possible to have a statement which consists of only a label field. 

The fields of a statement can be separated by spaces or tabs. There must be at least one space 
or tab separating the op-code field from the operand field, but spaces are unnecessary elsewhere. 
Spaces may appear in the operand field. Spaces and tabs are significant when they appear in a 
character string (for instance, as the operand of an . ascii pseudo-op) or in a character con- 
stant. In these cases, a space or tab stands for itself. 

A line is a sequence of zero or more statements, optionally followed by a comment, ending with a 
< newline> character. A line can be up to 4096 characters long. Multiple statements on a line 
are separated by semicolons. Blank lines are allowed. The form of a line is: 

[< statement > [ ; < statement > ...]][ j < comment> ] 


4.1. Label Field 

Labels are identifiers which the programmer may use to tag the locations of program and data 
objects. The format of a <label field> is: 


<identifier > : [ <identifier > :] . . . 


If present, a label always occurs first in a statement and must be terminated by a colon: 
sticky: | there is a label defined here. 

More than one label may appear in the same source statement, each one being terminated by a 
colon: 
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presson: grab: hold: | ther© ar© mu 1 tipi© labels defined her©. 

The collection of label definitions in a statement is called the label field. 

When a label is encountered in the program, the assembler assigns that label the value of the 
current location counter. The value of a label is relocatable. The symbol’s absolute value is 
assigned when the program is linked via the UNIX system ld( 1) command. 


4.2. Operation Code Field 

The operation code field of an assembly language statement identifies the statement as either a 
machine instruction or an assembler directive. 

One or more spaces (or tabs) must separate the operation code field from the following operand 
field in a statement. Spaces or tabs are unnecessary between the label and operation code fields, 
but they are recommended to improve readability of the program. 

A machine instruction is indicated by an instruction mnemonic. The assembly language state- 
ment is intended to produce a single executable machine instruction. The operation of each 
instruction is described in the manufacturer’s user manual. Some conventions used in as for 
instruction mnemonics are described in section 6 and a complete list of the instructions is 
presented in appendix B. 

An assembler directive, or pseudo-op, performs some function during the assembly process. It 
does not produce any executable code, but it may assign space for data in a program. 

Note that as expects that all instruction mnemonics in the op-code field should be in lower case 
only. Use of any upper case letters in instruction mnemonics gives rise to an error message. 

The names of register operands must also be in lower case only. This behavior differs from the 
case of identifiers, where both upper and lower case letters may be used and are considered dis- 
tinct. 

Many MC68010 machine instructions can operate upon byte (8-bit), word (16-bit), or long word 
(32-bit) data. The size which the programmer requires is indicated as part of the instruction 
mnemonic. For instance, a movb instruction moves a byte of data, a movw instruction moves a 
16-bit word of data, and a movl instruction moves a 32-bit long word of data. In general, the 
default size for data manipulation instructions is word. 

Similarly, branch instructions can use a long or short offset to indicate the destination. So the 
beq instruction uses a 16-bit offset, whereas the beqs uses a short (8-bit) offset. 

Note that this implementation of as provides an extended set of branch instructions which start 
with the letter j instead of the letter b. If the programmer uses the j forms, the assembler 
computes the offset size for the instruction. See section 1.1 for the assembler options which con- 
trol this. 


4.3. Operand Field 

The operand field of an assembly language statement supplies the arguments to the machine 
instruction or assembler directive. 
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As makes a distinction between the <operand field> and individual <operand8> in a machine 
instruction or assembler directive. Some machine instructions and assembler directives require 
two or more arguments, and each of these is referred to as an “operand”. 

In general, an operand field consists of zero or more operands, and in all cases, operands are 
separated by commas. In other words, the format for an <operand field> is: 


[<operand> [ 9 <operand>] . . .] 


The format of the operand field for machine instructions is the same for all instructions, and is 
described in section 6. The format of the operand field for assembler directives depends on the 
directive itself, and is included in the directive’s description in section 5 of this manual. 

Depending upon the machine instruction or assembler directive, the operand field consists of one 
or more operands. The kinds of objects which can form an operand are: 

® Register operands. 

© Expressions. 

These forms of operands are described in the subsections following. 


Register Operands 

Register operands in a machine instruction refer to the machine registers of the MC68010 proces- 
sor. 

Note that register names must be in lower case; as does not recognize register names in upper 
case or a combination of upper case and lower case. 


4.4. Comment Field 

As provides the means for the programmer to place comments in the source code. There are 
two ways of representing comments. 

A line whose first non-whitespace character is the hash character ( # ) is considered a comment. 
This feature is handy for passing C preprocessor output through the assembler. For example, 
these lines are comments: 

# This is a comment line. 

# And this one is also a comment line. 

The other way to introduce a comment is when a comment field appears as a part of a state- 
ment. The comment field is indicated by the presence of the vertical bar character ( | ) after the 
rest of the source statement. 

The comment field consists of all characters on a source line following and including the com- 
ment character. The assembler ignores the rest of line. Any character may appear in the com- 
ment field, with the obvious exception of the <newline> character, which starts a new line. 

An assembly language source line can consist of just the comment field. For example, the two 
statements below are quite acceptable to the assembler: 
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| This is a comment field. 
| So is this . 


4.5. Direct Assignment Statements 

A direct assignment statement assigns the value of an arbitrary expression to a specified 
identifier. The format of a direct assignment statement is: 

<identifier> = <expression> 


Examples of direct assignments are: 


vect_size 

vectora 

vectorb 

CRLF 


4 

OxFFFE 

vectora-vect_size 

OxODOA 


dtemp = dO 


use register dO as a temporary 


Any identifier defined by direct assignment may be redefined later in the program, in which case 
its value is the result of the last such statement. This is analogous to the SET operation found in 
other assemblers. 

A local identifier may be defined by direct assignment, though this doesn’t make much sense. 
Register identifiers may not be redefined. 

An identifier which has already been used as a label may not be redefined, since this would be 
tantamount to redefining the address of a place in the program. In addition, an identifier which 
has been defined in a direct assignment statement cannot later be used as a label. Both situa- 
tions give rise to an assembler error message. 

If the <ezpression> is absolute, the identifier is also absolute, and may be treated as a constant 
in subsequent expressions. If the <expression> is relocatable, however, the < identifier > is also 
relocatable, and it is considered to be declared the same program section as the expression. 

If the < expression^ contains an external identifier, the identifier defined by the = statement is 
also considered external. For example: 


. globl X | X is declared as external identifier 

holder = X | holder becomes an external identifier 

assigns the value of X (zero if it is undefined) to holder and makes holder an external 
identifier. External identifiers may be defined by direct assignment. 


4-4 


Revision E of 15 May 1985 



Chapter 5 


Assembler Directives 


Assembler directives are also known as pseudo operations or pseudo-ops. Pseudo-ops are used to 
direct the actions of the assembler, and to achieve effects such as generating data. The following 
pseudo-ops are available in as: 
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Table 5-1: Assembler Directives 


Pseudo 

Operation 

Description 

. ascii 

Generates a sequence of ASCII characters. 

. asciz 

Generates a sequence of ASCII characters, terminated by a zero byte. 

.byte 

Generates a sequence of bytes in data storage. 

. word 

Generates a sequence of words in data storage. 

. long 

Generates a sequence of long words in data storage. 

. text 

Specifies that generated code be placed in the text control section until further 
notice. 

. data 

Specifies that generated code be placed in the data control section until further 
notice. 

. datal 

Specifies that generated code be placed in the datal control section until further 
notice. 

. data2 

Specifies that generated code be placed in the data2 control section until further 
notice. 

.bss 

Specifies that space will be reserved in the bee control section until further no- 
tice. 

. globl 

Declares an identifier as global (external). 

. comm 

Declares the name and size of a common area. 

. lcomm 

reserves a specified amount of space in the bee area. 

. skip 

advances the location counter by a specified amount. 

. even 

forces location counter to next word (even byte) boundary. 

. stabs 

Builds special symbol table entries. These directives are for the benefit of com- 
pilers which generate information for the symbolic debugger dbx . 


These assembler directives are discussed in detail in the sections following. 


5.1. . ascii — Generate Sequence of Character Data 

The . ascii directive translates character strings into their ASCII equivalents for use in the 
source program. The format of the .ascii directive is: 

[</afce/> : ] .ascii ”<character string>” 

<character atring> 

contains any character or escape sequence which can appear in a character string. 
Obviously, a newline must not appear within the character string. A newline can be 
represented by the escape sequence \012. 
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The following examples illustrate the use of the . ascii statement: 

Octal Code Generated: Statement: 

150 145 154 154 157 040 .ascii "hello there" 

164 150 145 162 145 

127 141 162 156 151 156 .ascii "Warning-\007\007 \012" 

147 055 007 007 040 012 

141 142 143 144 145 146 .ascii "abcdefg" 

147 


5.2. . asciz — Generate Zero Terminated Sequence of Character 
Data 

The .asciz directive is equivalent to the .ascii directive except that a zero byte is 
automatically inserted as the final character of the string. This feature is intended for generat- 
ing strings which C programs can use. 

The following examples illustrate the use of the . asciz statement: 

Octal Code Generated: Statement: 

110 145 154 154 157 040 .asciz "Hello World!" 

127 157 162 144 041 000 

124 150 105 040 107 162 .asciz "The Great PROMpkin strikes again ! " 

145 141 164 040 120 122 

117 115 160 153 151 156 

040 163 164 162 151 153 

145 163 040 141 147 141 

151 156 041 000 


5.3. . byte, .word, .long — Generate Data 

The .byte, .word and .long directives reserve bytes, words, and long words, and initialize 
them with specified values. 

The format of the various forms of data generation statements is: 

[</afce/>:] .byte [<expression>] [, <expre8sion>] . . . 

[<.labet> : ] .word [<expres8ion>] [, <expression>] . . . 

[</a6e/>:] .long [<expre»»»'on>] [, <expres8ion>] . . . 

The .byte directive reserves one byte (8 bits) for each expression in the operand field, and ini- 

tializes the byte to the low-order 8 bits of the corresponding expression. 
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The .word directive reserves one word (16 bits) for each expression in the operand field, and 
initializes the word to the low-order 16 bits of the corresponding expression. 

The .long directive reserves one long word (32 bits) for each expression in the operand field, 
and initializes the long word to the low-order 32 bits of the corresponding expression. 

Multiple expressions can appear in the operand field of the .byte, .word, or .long direc- 
tives. Multiple expressions must be separated by commas. 

5.4. .text, .data, .bss — Switch Location Counter 

These statements change the ‘control section’ where assembled code will be loaded. 

As (and the UNIX system linker) view programs as divided into three distinct sections or address 
spaces: 

text is the address space where the executable machine instructions are placed. 

data is the address space where initialized data is placed. The assembler actually knows 
about three data areas, namely, data , datal y and data2 . The second and third data 
areas are mainly for the benefit of the C compiler and are of minimal interest to the 
assembly language programmer. 

If the — R option is coded on the as command line, it means that the initialized data 
should be considered read only. It is actually placed at the end of the text area. 

bss is the address space where the uninitialized data areas are placed. Also, see the 
. lcoxnm directive described below. 

For historical reasons, the different areas are frequently referred to as ‘control sections’ (csects 
for short). 

These sections are equivalent as far as as is concerned with the exception that no instructions or 
data are generated for the bss section — only its size is computed and its symbol values are out- 
put. 

During the first pass of the assembly, as maintains a separate location counter for each section. 
Consider the following code fragments: 


code : 

.text 

mow 

dl , d2 

| place the next instruction in the 

text section 

grab : 

. data 
. long 

27 

| now generate some data in the data 

section 

more : 

.text 

addw 

d2 , dl 

| now revert to the text section 


hold : 

.data 

.byt© 

4 

| and now back to the data section 



During the first pass, as creates the intermediate output in two separate chunks: one for the text 
section and one for the data section. 

In the text section, code immediately precedes more; in the data section, grab immediately 
precedes hold. At the end of the first pass, as rearranges all the addresses so that the sections 
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are sent to the output file in the order: text, data and bss. 

The resulting output file is an executable image file with all addresses correctly resolved, with 
the exception of undefined . globl’s and .comm’s. 

For more information on the format of the assembler’s output file, consult the UNIX System 
Programmer’s Reference Manual for the entry on a.out( 5). 


5.5. . skip — Advance the Location Counter 

The .skip directive reserves storage area by advancing the current location counter a specified 
amount. The format of the .skip directive is: 

.skip <siz©> 

where <size> is the number of bytes by which the location counter should be advanced. The 
.skip directive is equivalent to performing direct assignment on the location counter. For 
instance, a .skip directive like this: 

.skip 1000 

is equivalent to the direct assignment statement: 

. = . + 1000 


5.6. . lcomm — Reserve Space in .bss Area 

The . lcomm directive is a lazy way to get a specific amount of space reserved in the .bss area. 
The format of the . lcomm directive is: 

.lcomm <nam©>,<size> 

where <nome> is the name of the area to reserve, and < 0 « 2 e> is the number of bytes to 
reserve. The . lcomm directive specifically reserves the space in the .bss area, regardless of 
which location counter is currently in effect. 

A . lcomm directive like this: 

. lcomm lower_forty, 1200 

is equivalent to these directives: 

.bss | switch to .bss area 

lower_forty: .skip size 

revert to previous control section 
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5.7. . globl — Designate an Externa! Identifier 

A program may be assembled in separate modules, and then linked together to form a single exe- 
cutable unit. See the ld( 1) command in the UNIX Commands Reference Manual. 

External identifiers are defined in each of these separate modules. An identifier which is defined 
(given a value) in one module may be referenced in another module by declaring the identifiers 
as external in both modules. 

There are two forms of external identifiers, namely, those declared with the .globl and those 
declared with the .comm directive. The .comm directive is described in the next section. 

External symbols are declared with the .globl assembler directive. The format is: 

.globl <symbot> [, <symbot > ] . . . 


For example, the following statements declare the array TABLE and the routine SRCH as exter- 
nal symbols, and then define them as locations in the current control section: 


TABLE: 

SRCH: 


.globl TABLE, SRCH 
.word 0,0, 0,0,0 

mow TABLE , dO 

etc . . . 


5.8. . comm — Define Name and Si&e of a Common Area 

The .comm directive declares the name and size of a common area, for compatibility with FOR- 
TRAN and other languages which use common. The format of the .comm statement is: 

.comm <name > , < constant expression 

where name is the name of the common area, and constant expression is the size of the common 
area.The .comm directive implicitly declares the identifier name as an external identifier. 

as does not allocate storage for common symbols; this task is left to the linker. The linker com- 
putes the maximum declared size of each common symbol (which may appear in several load 
modules), allocates storage for it in the final bss section, and resolves linkages. If, however, 
<name> appears as a global symbol (label) in any module of the program, all references to 
<rjame> are linked to it, and no additional spaces is allocated in the .bss area. 


5.S. . even — Force Location Counter to Even Byte Boundary 

The .even directive advances the location counter to the next even byte boundary, if its 
current value is odd. This directive is necessary because word and long data values must lie on 
even byte boundaries, and also because machine instructions must start on even byte boundaries. 
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This chapter describes the conventions used in as to specify instruction mnemonics and address- 
ing modes. The information in this chapter is specific to the machine instructions and addressing 
modes of the MC68010 processor. 


6.1. Instruction Mnemonics 

The instruction mnemonics which as uses are based on the mnemonics described in the Motorola 
MC68010 processor manual. As deviates from the Motorola manual in several areas. 

Most of the MC68010 instructions can apply to byte, word or long operands. Instead of using a 
qualifier of .b, .w, or .1 to indicate byte, word, or long as in the Motorola assembler, as 

appends a suffix to the normal instruction mnemonic, thereby creating a separate mnemonic to 
indicate which length operand was intended. 

For example, there are three mnemonics for the or instruction: orb, orw and orl, meaning or 
byte, or word, and or long, respectively. 

Instruction mnemonics for instructions with unusual opcodes may have additional suffixes. Thus 
in addition to the normal add variations, there also exist addqb, addqw and addql for the 
add quick instruction. 

Branch instructions come in two flavors, byte (or short) and word. Append the suffix s to the 
word mnemonic to specify the short version of the instruction. For example, beq refers to the 
word version of the Branch if Equal instruction, while beqs refers to the short version of that 
instruction. 


@.2. Extended Branch Instruction Mnemonics 

In addition to the instructions which explicitly specify the instruction length, as supports 
extended branch instructions, whose names are, in most cases, constructed from the word ver- 
sions by replacing the b with j. These mnemonics should only be used in the text segment — 
if they are used in the data segment, the most general form of the branch is generated. 

If the operand of the extended branch instruction is a simple address in the text segment, and 
the offset to that address is sufficiently small, as automatically generates the corresponding short 
branch instruction. 

If the offset is too large for a short branch, but small enough for a branch, the corresponding 
branch instruction is generated. If the operand references an external address or is complex (see 
next paragraph), the extended branch instruction is implemented either by a jmp or jsr (for 
jra or jbsr), or by a conditional branch (with the sense of the conditional inverted) around a 
jmp for the extended conditional branches. 
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In this context, a complex address is either an address which specifies other than normal mode 
addressing, or a relocatable expression containing more than one relocatable symbol. For 
instance, if a , b and c are symbols in the current segment, the expression a+b—c is relocatable, 
but not simple. 

Consult appendix B for a complete list of the instruction op-codes. 

@.3. Addressing Modes 

The following table describes the addressing modes that as recognizes. The notations used in 
this table have these meanings: 

an refers to an address register, 

d n refers to a data register, 

r§ refers to either a data register or an address register, 

d refers to a displacement, which is a constant expression in as, 

xxx refers to a constant expression. 

Certain instructions, particularly move accept a variety of special registers including: 
sp the stack pointer which is equivalent to a7, 
sr the status register, 

cc the condition codes of the status register, 

usp the user mode stack pointer, 

pc the program counter, 

sfc the source function code register, 

dfc the destination function code register, 

Note that register a7 and the stack pointer (sp) are the same register. The only place where 
this is important is when the supervisor must explicitly use usp to refer to the user stack 
pointer. 
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Table 6-1: Addressing Modes 


Mode 

Notation 


Example 

Register 

an, dn, sp,pc, cc, sr, usp 

movw 

a3,d2 

Register Deferred 

a n@ 

movw 

a3@, d2 

Postincrement 

a«@+ 

movw 

a3@+,d2 

Predecrement 

an@- 

movw 

a3@-,d2 

Displacement 

an@ (d) 

movw 

a3@ (24) ,d2 

Word Index 

a m{d, Rs:W) 

movw 

a3@(16, d2 : W) , d3 

Long Index 

a n@(d, Ri:L) 

movw 

a3@(16, d2 : L) , d3 

Absolute Short 

xxx : VI 

movw 

14:W,d2 

Absolute Long 

xxx :L 

movw 

14:L,d2 

PC Displacement 

p c@(d) 

movw 

pc@ (20) ,d3 

PC Word Index 

pc@(rf, Rt: W) 

movw 

pc@(14, d2:W) , d3 

PC Long Index 

pc@(<i, Ri:L) 

movw 

pc@ (14, d2:L),d3 

Normal 

identifier 

movw 

widget, d3 

Immediate 

#xxx 

movw 

#27+3, d3 


Normal mode assembles as PC-relative if the assembler can determine that this is appropriate, oth- 
erwise it assembles as either absolute short or absolute long, under control of the — d2 command 
line option. 

The Motorola manual presents different mnemonics (and in fact different forms of the actual 
machine instructions) for instructions that use the literal effective address as data instead of 
using the contents of the effective address. For instance, the Motorola manual uses the 
mnemonic adda for add address, as does not make these distinctions because it can determine 
the type of the operand from the form of the operand. Thus an instruction of the form: 

avenue: .word 0 

add 1 #avenue , aO 

assembles to the add address instruction because as can determine that avenue is an address. 
right_now: = 40000 

addl #right_now, dO 

assembles to an add immediate instruction because as can determine that vight_now is a con- 
stant. 

Because of this determination of operand forms, some of the mnemonics listed in the Motorola 
manual are missing from the set of mnemonics that as recognizes. 

The MC68010 is restrictive in that certain classes of instructions accept only subsets of the 
address modes above. For example, the add instruction does not accept a PC-relative address as a 
destination. 
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as tries to check all these restrictions and generates the illegal operand error code for instruc- 
tions that do not satisfy the address mode restrictions. 

The next section below describes how the address modes are grouped into address categories. 

6.4. Addressing Categories 

The MC68010 groups the effective address modes into categories derived from the manner in 
which they are used to address operands. Note the distinction between address modes and 
address categories . There are 14 addressing mode@ ) and they fall into one or more of four 
addressing categories. The addressing categories are defined here, followed by a table which 
summarizes the grouping of the addressing modes into the categories. 

Data means that the effective address mode is used to refer to data operands such as a d 
register or immediate data. 

Memory means that the effective address mode can refer to memory operands. Examples 
include all the a-register indirect address modes and all the absolute address modes. 

Alterable means that the effective address mode refers to operands which are writeable (alter- 
able). This category takes in every addressing mode except the PC-relative address- 
ing modes and the immediate address mode. 

Control means that the effective address mode refers to memory operands without any expli- 
cit size specification. 

Some addressing categories can be combined to make more restrictive ones. So the Motorola 
MC68010 manual mentions things like Data Alterable Addressing Mode to mean that the particu- 
lar instruction can only use those modes which provided data addressing and are alterable as 
well. 
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Table 6-2: Addressing Categories 


Addressing 

Mode 

Assembler 

Syntax 

Date 

Memory 

Control 

Alterable 

Register Direct 

a n, d n, sp , pc, 
cc, sr, usp 

X 



X 

A Register Indirect 

an@ 

X 

X 

X 

X 

A Register Indirect 
with Post Increment 

&n@+ 

X 

X 


X 

A Register Indirect 
with Pre Decrement 

a n@- 

X 

X 


X 

A Register Indirect 
with Displacement 

an@ (d) 

X 

X 

X 

X 

A Register Indirect 
with Word Index 

&n@ (rf, ri: W) 

X 

X 

X 

X 

A Register Indirect 
with Long Index 

a n@ ( d , r«:L) 

X 

X 

X 

X 

Absolute Short 

xxx : W 

X 

X 

X 

X 

Absolute Long 

xxx : L 

X 

X 

X 

X 

PC-relative 

pc@ ( d) 

X 

X 

X 


PC-relative with 
with Word Index 

pc@ (d, ri: W) 

X 

X 

X 


PC-relative 
with Long Index 

pc@ (rf, r«: L) 

X 

X 

X 


Immediate Data 


X 

X 
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A.l. Usage Errors 

Unknown option ‘z’ ignored 

As does not recognize the option z. Valid options are listed in section 1.1. 


Cannot open source file 

The assembler cannot open a specified source file. Check the spelling, that the pathname 
supplied is correct, and that you have read permission on that file. 


Too many file names given 

The assembler can’t cope with more than one source file. 


Break the job into smaller stages. 


Cannot open output file 

The specified output file cannot be created, 
file. 


Check that the permissions allow opening this 


No input file 

Exactly one input file must be specified — as cannot acept the output of a pipe as its input. 


A.2. Assembler Error Messages 

If as detects any errors during the assembly process, it prints out a message of the form: 
as: error (< lin©_no>) : <error__code> 

Error messages are sent to standard error. Here is a list of as error codes, and their possible 
causes. 

Invalid Character 

An unexpected character was encountered in the program text. 


Revision E of 15 May 1985 


A-l 



Error Codes 


Assembly Language Reference Manual 


Multiply defined symbol 

© An identifier appears twice as a label. 

© An attempt to redefine a label using an = (direct assignment) statement. 

© An attempt to use, as a label, an identifier which was previously defined in an — (direct 
assignment) statement. 

Symbol storage exceeded 

No more room is left in the assembler’s symbol table. Cut the program into smaller por- 
tions; assemble portions of the program separately, then bind them together using the linker. 


Out of strings space 

No more room is left in the assembler’s internal string table. Cut the program into smaller 
portions; assemble portions of the program separately, then bind them together using the 
linker. 


Stab storage exceeded 

No more room is left in the assembler’s symbol table for debug information. Cut the pro- 
gram into smaller portions; assemble portions of the program separately, then bind them 
together using the linker. 


Invalid Constant 

An invalid digit was encountered in a number. For example, using an 8 or 9 in an octal 
number. Also happens when an out-of-range constant operand is found in an instruction — 
for example: 

addq #200, dO 
asll #12, dO 


Invalid Term 

The expression evaluator could not find a valid term: symbol, constant or \<expression>]. 
An invalid prefix to a number or a bad symbol name in an operand generates this message. 


Invalid Operator 

Check the operand field for a bad operator. The operators that as recognizes are plus ( + ), 
minus ( - ), negate or one’s complement ( ' ), multiply ( * ), and divide ( / ). 


Non-relocatable expression 

If an expression contains a relocatable symbol (a label, for instance), the only operations that 
can be applied to it are the addition of absolute expressions or the subtraction of another 
relocatable symbol (which produces an absolute result). 

Invalid operand 

The operand used is not consistent with the instruction used — for example: 
addqb #l,a5 

is an invalid combination of instruction and operand. Check the instruction set descriptions 
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for valid combinations of instructions and operands. 

Invalid symbol 

An operand that should be a symbol is not — for example: 

. globl 3 

because the constant 3 is not a symbol. 

Invalid assignment 

An attempt was made to redefine a label with an = statement. 

Invalid op-code 

The assembler did not recognize an instruction mnemonic. Probably a misspelling. 

Invalid string 

An invalid string was encountered in an . ascii or . asciz directive. 

® Make sure the string is enclosed in double quotes. 

9 Remember that you must use the sequence \" to represent a double quote inside a string. 
Wrong number of operands 

Check appendix B for the correct number of operands for the current instruction. 

Line too long 

A statement was found which has more than 4096 characters before the newline. 

Invalid register expression 

A register name was found where one should not appear — for example: 
add #dO ,_ther© 

Offset too large 

The instruction is a relative addressing instruction and the displacement between this 
instruction and the label specified is too large for the address field of the instruction. 

Odd address 

The previous instruction or pseudo-op required an odd number of bytes and this instruction 
requires word alignment. This error can only follow an .ascii, an .asciz, a .byte, or 
a .skip pseudo-operation. 

© Use a .even directive to ensure that the location counter is forced to a 16-bit boundary. 
Undefined L-symbol 

This is a warning message. A symbol beginning with the letter ‘L’ was used but not defined. 
It is treated as an external symbol. Compiler-generated labels usually start with the letter 
‘L’ and should be defined in this assembly. The absence of such a definition usually indicates 
a compiler code generation error. This message is also generated by the use of symbols such 
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as $99 or n$ if has not been defined. 
Missing close-par en ’)’ 

An unmatched ‘(’ was found in an expression. 
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List of As Opcodes 


This appendix is a list of the instruction mnemonics, grouped alphabetically. 

Each entry describes the following things: 

® The mnemonics for the instruction, 

• The generic name for the instruction, 

• The assembly language syntax and the variations on the instruction, 

© The condition codes that this instruction affects. 

The syntax for as machine instructions differs somewhat from the instruction layouts and 
categories shown in the Motorola MC68010 manual. For example, as provides a single set of 
mnemonics for add (add binary), adda (add address), and addi (add immediate). In general, as 
selects the appropriate instruction from the form of the operands. 

Here is a brief explanation of the notations used below. 

® An instruction of the form adda: in the assembly language syntax column means that the 
instruction is coded as addb or addw or addl, etcetera. 

© An operand field of an means any A-register. 

© An operand field of dn means any D-register. 

® An operand field of rn means any A- or D-register. 

© An operand field of ea means an effective address designated by one of the permissible 
addressing modes for the MC68010. Consult the Motorola MC68010 manual for details of the 
allowed addressing modes for each instruction. 

@ An operand field of ftdata means an immediate operand. 

® Other special registers such as cc (condition code register) and sr (status register) are 
specifically indicated where appropriate. 

© The condition code register has the following flags, with the following meanings. 

N Set if the most significant bit of the result is set. Cleared otherwise. 

Z Set if the result is zero. Cleared otherwise. 

V Set if there was an arithmetic overflow. Cleared otherwise. 

C Set if a carry is generated (for addition) or a borrow is generated (for a subtraction) out 
of the most significant bit of the operand. Cleared otherwise. 

X This condition code is transparent to data movement instructions. When it is affected it 
is set the same as the C (carry) condition. 
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® The notations under condition codes in the tables below have these meanings: 

* set according to the result of the instruction. 

— this instruction does not affect this condition code. 

0 this instruction clears this condition code. 

1 this instruction sets this condition code. 

U this condition code is undefined after the instruction. 

? this condition code is set according to the status register pulled off the stack, or according 
to the immediate operand. 


Mnemonics 

Operation 

Assembly Lanquage 


Condition 



Syntax 



Codes 






X 

N 

Z V 

c 

abed 

add decimal 

with extend 

abed 

abed 

d y, d® 

ay@- , az@- 

* 

U 

* u 

* 

addb 


ad d# 

ea, d^ 





addw 

add binary 

add # 

add# 

dn, ea 

ea , an 

♦ 

* 

* * 

* 

addl 


add# 

ftdata, ea 





addqb 

addqw 

addql 

add quick 

addq# 

#data, ea 

* 

$ 

* * 

* 

addxb 


addx# 

dy.dx 





addxw 

addxl 

add extended 

addx# 

ay@- , a#@- 

❖ 

* 

* * 

* 

andb 


and# 

ea, dn 





andw 

logical and 

and# 

dn, ea 

* 

* 

* * 

* 

andl 


and# 

ftdata, ea 





aslb 


asl# 

dx, d y 





aslw 

arithmetic shift left 

asl# 

ftdata, dy 

* 

* 

* * 

* 

asl 1 


asl# 

ea 





asrb 


asr# 

dx , dy 





asrw 

arithmetic shift right 

asr# 

#data, dy 

* 

♦ 

* * 

* 

asr 1 


asr# 

ea 





bcc 

bees 

branch carry clear 

bee# 

ea 

— 

— 

— — 

— 

bchg 

test a bit and change 

bchg 

bchg 

dn, ea 
ftdata, ea 

— 

— 

* _ 

— 

bclr 

test a bit and clear 

bclr 

bclr 

dn, ea 
#data, ea 

— 

— 

* _ 

— 


test a bit and set 

bs©t 

dn, ea 



* 


bset 

bs©*t 

#data, ea 







btst 

dn, ea 
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Mnemonics 

Operation 

Assembly Language 

Syntax 


Condition 

Codes 






X 

N 

z 

V 

c 



btst 

§data, ea 






bcs 

bcss 

branch carry set 

hcsx 

ea 

— 

— 

— 

— 

— 

beq 

beqs 

branch on equal 

beqz 

ea 

— 

— 

— 

— 

— 

bg© 

bges 

branch greater or equal 

bgez 

ea 

— 

— 

— 

— 

— 

bgt 

bgts 

branch greater than 

bgtz 

ea 

— 

— 

— 

— 

— 

bhi 

bhis 

branch higher 

bhi x 

ea 

— 

— 

— 

— 

— 

ble 

bles 

branch less than or equal 

bl©z 

ea 



— 

— 

— 

bis 

blss 

branch lower or same 

blsz 

ea 

— 

— 

— 

— 

— 

bit 

bits 

branch less than 

bltz 

ea 

— 

— 

— 

— 

— 

bmi 

bmis 

branch minus 

i n. 

bmiz 

ea 

— 

— 


— 

— 

btst 




— 

— 


— 

— 

bn© 

bnes 

branch not equal 

bnez 

ea 

— 

— 

— 

— 

— 

bpl 
bp Is 

branch positive 

bplz 

ea 

— 

— 

— 

— 

— 

bra 

bras 

branch always 

braz 

ea 

— 

— 

— 

— 

— 

bsr 

bsrs 

subroutine branch 

bsrz 

ea 

— 

— 

— 

— 

— 

bvc 

bvcs 

branch overflow clear 

bvcz 

ea 

— 

— 

— 

— 

— 

bvs 

bvss 

branch overflow set 

bvsz 

ea 

— 


— 

— 

— 

chk 

check register 
against bounds 

chk 

ea, d n 

— 

♦ 

u 

u 

u 

clrb 

clrw 

clrl 

clear an operand 

clrs 

ea 

— 

0 

1 

0 

0 

cmpmb 

cmpmw 

cmpml 

compare memory 

cmpmz 

ay@+, Ax@+ 

— 

* 

♦ 

* 

♦ 
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Mnemonics 

Operation 

Assembly Language 

Syntax 


Condition 

Codes 






X 

N 

Z 

V 

c 

cmpb 

cmpw 

cmpl 

arithmetic compare 

cmpx 

cmp x 

ea, dn 

ftdata, ea 

— 

❖ 

* 

* 

* 

dbcc 

decrement & branch 
on carry clear 

dbcc 

dn, label 

— 

— 

— 

— 

— 

dbcs 

decrement & branch 
on carry set 

dbcs 

dn, label 

— 

— 

— 

— 

— 

dbeq 

decrement & branch 
on equal 

dbeq 

dn, label 

— 

— 

— 

— 

— 

dbf 

decrement & branch 
on false 

dbf 

dn, label 

— 

— 

— 

— 

— 

dbg© 

decrement & branch 
on greater than or equal 

dbg© 

dn, label 

— 

— 

— 

— 

— 

dbgt 

decrement & branch 
on greater than 

dbgt 

dn, label 

— 

— 

— 

— 

— 

dbhi 

decrement & branch 
on high 

dbhi 

dn, label 

— 

— 


— 

— 

dble 

decrement & branch 
on less than or equal 

dble 

dn, label 

— 

— 

— 

— 

— 

dbls 

decrement & branch 
on low or same 

dbls 

dn, label 

— 

— 

— 

— 

— 

dblt 

decrement & branch 
on less than 

dblt 

dn, label 

— 

— 


— 

— 

dbmi 

decrement & branch 
on minus 

dbmi 

dn, label 


— 

— 

— 

— 

dbn© 

decrement & branch 
on not equal 

dbn© 

dn, label 

— 

— 

— 

— 

— 

dbpl 

decrement & branch 
on plus 

dbpl 

dn, label 

— 

— 

— 

— 

— 

dbra 

decrement & branch 
always (same as dbf) 

dbra 

dn, label 

— 

— 

— 

— 

— 

dbt 

decrement & branch 
on True 

dbt 

dn, label 

— 

— 

— 

— 

— 

dbvc 

decrement & branch 
on overflow clear 

dbvc 

dn, label 

— 

— 

— 

— 

— 

dbvs 

decrement & branch 
on overflow set 

dbvs 

dn, label 

— 

— 

— 

— 

— 

divs 

signed divide 

divs 

ea, dn 

— 

* 

* 

* 

0 

divu 

unsigned divide 

divs 

ea, dn 


* 

* 

* 

0 

eorb 

logical exclusive or 

oorx 

dn, ea 

— 

* 

* 

0 

0 

aorw 


Gorx 

#data, ea 






©orl 


©orb 

%data, cc 








©orw 

#data, sr 
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Mnemonics 

Operation 

Assembly Language 

Syntax 


Condition 

Co deo 






X 

N 

Z 

V 

c 

©xg 

exchange registers 

©xg 

rx,ry 

— 

— 

— 

— 

— 

extw 

extl 

sign extend 

©xt 

d n 

— 

* 

* 

0 

0 

jmp 

jump 

jmp 

ea 

— 

— 

— 

— 

— 

jsr 

jump to subroutine 

jsr 

ea 

— 

— 

— 

— 

— 

jcc 

jump carry clear 

jcc 

ea 

— 

— 

— 

— 

— 

jcs 

jump on carry 

jcs 

ea 

— 

— 


— 

— 

jeq 

jump on equal 

jeq 

ea 

— 

— 

— 

— 

— 

jg® 

jump greater or equal 

jga 

ea 

— 

— 

— 

— 

— 

jgt 

jump greater than 

jgt 

ea 

— 

— 

— 

— 

— 

jhi 

jump higher 

jhi 

ea 

— 


— 

— 

— 

jle 

jump less than or equal 

jl© 

ea 

— 


— 

— 

— 

jls 

jump lower or same 

jls 

ea 

— 

— 

— 

— 

— 

jit 

jump less than 

jit 

ea 


— 

— 

— 

— 

jmi 

jump minus 

jmi 

ea 

— 

— 

— 

— 

— 

jne 

jump not equal 

jn© 

ea 

— 

— 


— 

— 

jpi 

jump positive 

jpi 

ea 


— 

— 

— 

— 

jra 

jump always 

jra 

ea 


— 

— 

— 

— 

jbsr 

jump to subroutine 

jbsr 

ea 


— 

— 

— 

— 

j VC 

jump no overflow 

jvc 

ea 

— 

— 

— 

— 

— 

jvs 

jump on overflow 

jvs 

ea 

— 

— 

— 

— 

— 

lea 

load effective address 

lea 

ea, a n 

— 

— 

— 

— 

— 

link 

link and allocate 

link 

an, #disp 

— 

— 

— 

— 

— 

lslb 

logical shift left 

lslz 

dx.dy 

* 

* 

* 

0 

* 

lslw 


Isis 

%data,dy 






lsll 


Islz 

ea 






Isrb 

logical shift right 

Isrx 

dx,dy 

* 

* 

* 

0 

* 

lsrw 


lsr x 

#data, dy 






Isr 1 


Isrx 

ea 






movb 

move data 

movx 

ea, ea 

— 

* 

* 

0 

0 

movw 


movx 

#data, drc 






xnovl 









movw 

move from 

condition code register 

movw 

cc, ea 

— 

“ 

— 

— 

— 

movw 

move from status register 

movw 

s r , ea 

— 

— 


— 

— 

move 

move to control register 

move 

rn, cr 

— 

— 

— 

— 

— - 

move 

move from control register 

move 

cr, rn 




— 

— 

mo vein 1 

move multiple registers 

movemw 

ftmask, ea 

— 

— 

— 

— 

— 

movemw 


movemw 

ea, ftmask 






movepl 

move peripheral 

mov©p# 

dn, a n@ (d) 

— 

— 

— 

— 

— 

movepw 


movepl 

dn, a rt@(d) 
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Assembly Language 

Syntax 

X 

Condition 

Codes 

N Z V 

c 

moveq 

move quick 

moveq 

%data. dn 

— 

* 

* 

0 

0 

movsb 

move to address space 

movsi 

rn, ea 

— 

— 

— 

— 

— 

movsw 

move from address space 

movsz 

ea, rn 






movsl 









muls 

signed multiply 

muls 


0 

0 

* 

* 

0 

mulu 

unsigned multiply 

mulu 

RjEBHIR 

0 

0 

* 

* 

0 

nbcd 

negate decimal with extend nbcd 

ea 

* 

u 

* 

u 

* 

negb 

negate binary 

negx 

ea 

* 

♦ 

* 

* 

* 

negw 









negl 









negxb 

negate binary with extend 

negxx 

ea 

❖ 

♦ 

♦ 

* 

* 

negxw 









negxl 









nop 

no operation 

nop 


— 

— 

— 

— 

— 

noth 

logical complement 

notx 

ea 

— 

♦ 

* 

0 

0 

notw 









notl 









orb 

inclusive or 

orx 

ea, dn 

— 

* 

* 

0 

0 

orw 


orx 

dre, ea 






or 1 


or 

ftdata, ea 








orb 

#data, cc 








orw 

#data, sr 






pea 

push effective address 

pea 

ea 

— 

— 

— 

— 

— 

reset 

reset machine 

reset: 


— 

— 

— 

— 

— 

rolb 

rotate left 

rolz 

dx, dy 

0 

* 

* 

0 

* 

rolw 


rolz 

ftdata, dy 






roll 


rolz 

ea 






rorb 

rotate right 

rorz 

dx, dy 

0 

* 

♦ 

0 

* 

rorw 


rorx 

%data, dy 






ror 1 


rorx 

ea 






roxlb 

rotate left with extend 

roxlx 

dx, dy 

♦ 

* 

* 

0 

* 

roxlw 


roxl x 

#data, dy 






roxll 


roxlx 

ea 






roxrb 

rotate right with extend 

roxrx 

dx, dy 

* 

* 

* 

0 

* 

roxrw 


roxrx 

%daia, dy 






roxrl 


roxrx 

ea 






rt© 

return from exception 

rt© 


? 

? 

? 

? 

? 

rtr 

return and restore codes 

rtr 


? 

? 

? 

? 

? 

rts 

return from subroutine 

rts 


— 

— 

— 

— 

— 

rts 

return from subroutine 

rts 

#n 

— 

— 

— 

— 

— 
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Codes 

X N Z V C 

sbcd 

subtract decimal with extencfebcd dy,dx 

* U * U * 


sbcd 


stop 

halt machine 

stop 

#xzx 

? 

? 

? 

? 

? 

subb 

arithmetic subtract 

sub# 

ea, dn 

* 

* 

* 

* 

* 

subw 


sub# 

dra, ea 








sub# 

ea, a n 






subl 


sub# 

ftdata, ea 






st 

set all ones 

st: 

ea 

— 

— 

— 

— 

— 

sf 

set all zeros 

sf 

ea 

— 

— 

— 

— 

— 

shi 

set high 

shi 

ea 

— 

— 

— 

— 

— 

sis 

set lower or same 

sis 

ea 

— 

— 

— 

— 

— 

see 

set carry clear 

sec 

ea 

— 

— 

— 

— 

— 

ses 

set carry set 

scs 

ea 

— 

— 

— 

— 

— 

sne 

set not equal 

sne 

ea 

— 

— 

— 

— 

— 

seq 

set equal 

seq 

ea 

— 

— 

— 

— 

— 

SVC 

set no overflow 

sve 

ea 

— 

— 

— 

— 

— 

SVS 

set on overflow 

SVS 

ea 

— 

— 

— 

— 

— 

spl 

set plus 

spl 

ea 

— 

— 

— 

— 

— 

smi 

set minus 

smi 

ea 

— 

— 

— 

— 

— 

sg© 

set greater or equal 

sg© 

ea 

— 

— 

— 

— 

— 

sit 

set less than 

sit 

ea 

— 

— 

— 

— 

— 

sgt 

set greater than 

sgt 

ea 

— 

— 

— 

— 

— 

sle 

set less than or equal 

si© 

ea 

— 

— 

— 

— 

— 

subqb 

subtract quick 

subq# 

ftdata, ea 

* 

* 

♦ 

* 

* 

subqw 









subql 









subxb 

subtract extended 

subx# 

dy.dx 

♦ 

♦ 

* 

* 

* 

subxw 


subx# 

ay@- , ai@- 






subxl 









swap 

swap register halves 

swap 

dn 

* 

* 

* 

* 

* 

tas 

test operand then set 

tas 

ea 

— 

* 

♦ 

0 

0 

trap 

trap 

trap 

# vector 

— 

— 

— 

— 

— 

trapv 

trap on overflow 

trapv 


— 

— 

— 

— 

— 

tstb 

test operand 

tst# 

ea 

— 

* 

* 

0 

0 

tstw 









tstl 









unlk 

unlink 

unlk 

a n 

— 

— 

— 

— 

— 
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